- 
                Notifications
    You must be signed in to change notification settings 
- Fork 13.9k
ast: Keep expansion status for out-of-line module items #82238
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
| r? @estebank (rust-highfive has picked a reviewer for you, use r? to override) | 
| r? @Aaron1011 | 
        
          
                compiler/rustc_ast/src/mut_visit.rs
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Constructing this synthetic Mod seems kind of unfortunate, but it looks like it's necessary for the flat_map_item handling below.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't like this either and left a FIXME above.
I'll try to investigate removing this some time later, together with similar code in fn expand_crate.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could this be moved to the ItemKind::Mod(..) =>  match arm below? That would allow you to avoid using lctx.modules.entry in some of the other code.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think entry is preferable, why pre-inserting empty values explicitly if entry can do everything for you automatically.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I thought that the get_mut().unwrap() might have been a check to ensure that we had already processed the module in some way. If that's not the case, then I think your change is fine.
Crate root is sufficiently different from `mod` items, at least at syntactic level. Also remove customization point for "`mod` item or crate root" from AST visitors.
Also remove `ast::Mod` which is mostly redundant now
1e0132e    to
    4a88165      
    Compare
  
    | self.end(); // end inner head-block | ||
| self.end(); // end outer head-block | ||
| match mod_kind { | ||
| ModKind::Loaded(items, ..) => { | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It looks like this will always pretty-print the contents of outline modules - is that intentional?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For --pretty=normal and --pretty=expanded this is a replacement of the removed self.is_expanded flag.
For synthesizing tokens for inner macro attributes on modules (which are broken until #81661 is fixed) I think it also makes sense to tokenize the whole module rather than just the mod foo; header.
| r=me assuming that the pretty-printer change is intentional. | 
| @bors r+ | 
| 📌 Commit 4a88165 has been approved by  | 
Rollup of 10 pull requests Successful merges: - rust-lang#79747 (Add explanations and suggestions to `irrefutable_let_patterns` lint) - rust-lang#81496 (name async generators something more human friendly in type error diagnostic) - rust-lang#81873 (Add Mutex::unlock) - rust-lang#82093 (Add tests for Atomic*::fetch_{min,max}) - rust-lang#82238 (ast: Keep expansion status for out-of-line module items) - rust-lang#82245 (Do not ICE when evaluating locals' types of invalid `yield`) - rust-lang#82259 (Fix popping singleton paths in when generating E0433) - rust-lang#82261 (rustdoc: Support argument files) - rust-lang#82274 (libtest: Fix unwrap panic on duplicate TestDesc) - rust-lang#82275 (Update cargo) Failed merges: r? `@ghost` `@rustbot` modify labels: rollup
ast: Keep expansion status for out-of-line module items I.e. whether a module `mod foo;` is already loaded from a file or not. This is a pre-requisite to correctly treating inner attributes on such modules (rust-lang#81661). With this change AST structures for `mod` items diverge even more for AST structure for the crate root, which previously used `ast::Mod`. Therefore this PR removes `ast::Mod` from `ast::Crate` in the first commit, these two things are sufficiently different from each other, at least at syntactic level. Customization points for visiting a "`mod` item or crate root" were also removed from AST visitors (`fn visit_mod`). `ast::Mod` itself was refactored away in the second commit in favor of `ItemKind::Mod(Unsafe, ModKind)`.
expand: Turn `ast::Crate` into a first class expansion target And stop creating a fake `mod` item for the crate root when expanding a crate, thus addressing FIXMEs left in rust-lang#82238, and making a step towards a proper support for crate-level macro attributes (cc rust-lang#54726). I haven't added token collection support for the whole crate in this PR, maybe later. r? `@Aaron1011`
I.e. whether a module
mod foo;is already loaded from a file or not.This is a pre-requisite to correctly treating inner attributes on such modules (#81661).
With this change AST structures for
moditems diverge even more for AST structure for the crate root, which previously usedast::Mod.Therefore this PR removes
ast::Modfromast::Cratein the first commit, these two things are sufficiently different from each other, at least at syntactic level.Customization points for visiting a "
moditem or crate root" were also removed from AST visitors (fn visit_mod).ast::Moditself was refactored away in the second commit in favor ofItemKind::Mod(Unsafe, ModKind).